草庐IT

Java in 运算符

全部标签

c# - 隐式运算符应该处理 null 吗?

我们有一个具有隐式字符串运算符的类型。它看起来像这样:publicclassFoo{readonlystring_value;Foo(stringvalue){_value=value;}publicstaticimplicitoperatorstring(Foofoo){returnfoo._value;}publicstaticimplicitoperatorFoo(stringfooAsText){returnnewFoo(fooAsText);}}我们刚刚遇到这样一种情况,其中传递给隐式运算符的实例是null。显然,我们以NullReferenceException结束。我认为

c# - XML 文档中的引用运算符

我想在中引用一个运算符XMLdocumentation标签,但我似乎找不到任何关于如何操作的提示。MSDNarticle在这个标签上只展示了一个引用方法的简单例子,并没有涉及可以引用的不同类型的成员。特别是,我想引用一个隐式转换运算符,但也欢迎引用运算符的一般规则。例子假设我们有一个简单的结构,我们为其定义了==,!=和隐式转换运算符:publicstructMyStructure{publicintValue{get;set;}publicstaticbooloperator==(MyStructurex,MyStructurey)=>x.Value==y.Value;publics

c# - 为什么 C# 5.0 await 关键字被列为运算符而不是修饰符?

MSDN库liststheawaitkeywordasanoperator.这对我来说似乎很奇怪-我以为它是一个修饰符,比如theasynckeyword.为什么这是一个运算符? 最佳答案 async是声明的修饰符。类似于public.await是一种使用异步运算符并对其执行某些操作的操作。类似于return.await不是修改放在它后面的内容,而是指定如何处理该操作。对比async实际上并没有修改任何东西,它只是标记一个特定的方法是async的样式(从语法的角度来看,最终的await执行了对方法结构的所有更改)。

c# - 重载的 false 运算符什么时候被执行,它有什么用?

我一直在寻找实际执行重载的false运算符的实际工作代码。Thisquestion(What'sthefalseoperatorinC#goodfor?)有点相同,但接受的答案链接到返回404错误的url。我也看过Howdoesoperatoroverloadingoftrueandfalsework?以及其他一些问题。我在几乎所有答案中发现的是,false仅在您使用短路和类似x&&y时才会执行。这被评估为T.false(x)?x:T.&(x,y).好的,所以我有以下代码。struct包含一个int并且如果int大于零则认为它自己为真。:publicstructMyStruct{pri

c# - 当一个操作数是接口(interface)时,回退到 Object 的 == 运算符的原因是什么?

考虑以下类型:classA{}classB{}interfaceIC{}Aa=null;//thevaluedoesn'tmatter-nulloranythingelse,forallthreeBb=null;ICc=null;以下doesnotcompile:varx=a==b;但是以下确实编译(正如我惊讶地发现的那样):varx=a==c;据我所知,编译器回退到使用默认的==运算符,它是在对象上定义的,因此接受任何类型的参数。IL看起来像这样(忽略ldfld的细节):ldarg.0ldfldclassAaldarg.0ldfldclassICcceqstloc.0换句话说,它使用

c# - 非短路 bool 运算符和 C# 7 模式匹配

我目前正在编写一个C#应用程序,目标是.NET4.7(C#7)。在尝试使用使用“is”关键字声明变量的新方法后,我感到很困惑:if(变量是MyClassclassInstance)这样就可以了,但是在做的时候:if(true&variableisMyClassclassInstance){vara=classInstance;}VisualStudio(我使用的是2017)向我显示错误Useofunassignedlocalvariable'classInstance'。使用&(&&)的短路版本它工作正常。我是否遗漏了有关&运算符的内容?(我知道使用短路版本更常用,但此时我只是好奇)

c# - 在 C# 中使用运算符构建自定义表达式树

这个问题是关于使用C#(或任何其他语言)中的运算符在.NET中构建自定义表达式树。我提供了问题以及一些背景信息。对于我的managed2-phase64-bitassembler我需要对表达式的支持。例如,一个人可能想要组装:mystring:DB'hello,world'TIMES64-$+mystringDB''表达式64-$+mystring不能是一个字符串,而是一个实际有效的表达式,具有语法和类型检查以及VS中的IntelliSense的优点,类似于:64-Reference.CurrentOffset+newReference("mystring");此表达式在构造时不会求值

c# - C# 中的运算符重载

classPoint{privateintm_PointX;privateintm_PointY;publicPoint(intx,inty){m_PointX=x;m_PointY=y;}publicstaticPointoperator+(Pointpoint1,Pointpoint2){PointP=newPoint();P.X=point1.X+point2.X;P.Y=point1.Y+point2.Y;returnP;}}例子:PointP1=newPoint(10,20);PointP2=newPoint(30,40)P1+P2;//operatoroverloading

c# - 空合并运算符是否在c#中缓存结果

我知道(myValue??newSomeClass())类似于(myValue==null?newSomeClass():myValue)但出于好奇,当我调用函数时是否有任何性能优势,比如(getResult()??newSomeClass())。getResult()会被执行两次吗?这似乎不直观,因为我只指定了一次方法调用。 最佳答案 好吧,如果您所说的“缓存”是指将其存储在一个临时变量中,那么是的。这个结构:varresult=(getResult()??newSomeClass());可以认为等价于此:var=getResul

c# - 位运算练习

我有以下练习:数字n0到n7是以二进制系统表示的字节。任务是每一位都掉到底部,或者如果它遇到另一位,它就会停留在它上面。这是一个视觉示例:我意识到,如果我对从n0到n7的所有数字应用按位或,它始终是n7的正确结果:n7=n0|n1|n2|n3|n4|n5|n6|n7;Console.WriteLine(n7);//n7=236不幸的是,我想不出其余字节n6、n5、n4、n3、n2、n1、n0的正确方法。你有什么想法吗? 最佳答案 我想提出一个不会遍历集合N次的解决方案,我相信我已经找到了一种新颖的分而治之方法:intn0_,n1_,